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INTERNET-ENABLED CONFERENCING SYSTEM AND METHOD 
ACCOMMODATING PSTN AND IP TRAFFIC 

RELATED APPLICATIONS 

This application is related to copending U.S. Application No. 09/ , , filed 

February 29, 2000 by J. Larry Summers, Paul D. Harmon, and Trey H. Smith, for an 
Internet-enabled conferencing system and method accommodating PSTN and IP traffic. 

TECHNICAL FIELD OF THE INVENTION 

This invention relates in general to the field of communications and in particular 
to an Internet-enabled conferencing system and method accommodating PSTN and IP 
traffic. 
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BACKGROUND OF THE INVENTION 

Communications needs continue to expand on a global scale. With the growing 
demand for communications, there is a concurrent expansion in the demand for audio, 
video, and combined audio and video conferencing. The ability for multiple parties to 
5 communicate with one another is very much a requirement for modern business. As 

individuals and organizations seek to decrease their costs and improve productivity, 
identifying relatively inexpensive, reliable, and effective conferencing solutions has 
become increasingly important. This is particularly true considering the recent rise in 
importance of packet-based audio, video, and other communications relying on Internet 

1 0 Protocol (IP). 

Multi-party bridging provides a foundation for conferencing and has existed for 
some time in the form of analog ("dumb") bridges handling public switched telephone 
network (PSTN) traffic, which require operator services or other appropriate intelligent 
front end capability. The number of conferees is typically limited to eight or fewer. 

1 5 Similar limitations exist for prior conferencing systems for handling IP traffic. Such 

systems are host-based, with bridging being performed using a general purpose central 
processing unit (CPU) within a "Media Server" or other computer system, and provide 
limited teleconferencing capacity, hi many cases, a "push to talk" control key must be 
manipulated. Desirable features such as echo cancellation, automatic gain control, and 

20 simultaneous speaking are very difficult to implement. Furthermore, due to the nature 

of IP networks, packets are often lost or delayed, distorting voice audio or freezing an 
image on the viewing screen. Even in managed IP networks, congestion may cause 
temporary data loss for one or more conferees. Such quality of service issues must be 
carefully considered in assessing the usefulness of conferencing systems expected to 

25 handle IP traffic. While possibly adequate for casual use, such systems are typically not 
sufficiently robust for important business communications. 

To deploy a traditional PSTN conference bridge within an IP network requires a 
separate "gateway" to convert the IP packets carrying conference audio and video into 
digital or analog telephone traffic before routing it to the bridge. In addition to other 

30 deficiencies noted above with respect to existing pure PSTN or pure IP solutions, such 

gateways must be paid for and managed. As a result of these and other deficiencies, 
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previous techniques are often inadequate to meet conferencing requirements of many 
business and other users. 
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SUMMARY OF THE INVENTION 

According to the present invention, disadvantages and problems associated with 
previous conferencing techniques are substantially reduced or eliminated. 

According to one embodiment of the present invention, a system for scheduling 
5 a conference between callers includes a database that stores scheduling information 

indicating at least a start time, a duration, and a maximum number of callers for one or 
more scheduled conferences, the scheduling information reflecting available conferencing 
resources. A server complex coupled to the database communicates, to a requesting 
Internet Protocol (IP) user, at least one page including one or more scheduling input 

10 fields. The server complex receives scheduling input from the requesting IP user for a 

requested conference according to the scheduling input fields. The server complex 
accesses the database to determine, according to the scheduling input, whether sufficient 
conferencing resources are available for the requested conference. If so, the server 
complex allocates at least some of the available conferencing resources to the requested 

1 5 conference and generates confirmations of the requested conference for communication 

to the callers. 

According to another embodiment of the present invention, software associated 
with an IP user includes conference scheduling software and control software. The 
scheduling software provides at least one page to the IP user that includes one or more 

20 scheduling input fields for a requested conference involving at least one public switched 

telephone network (PSTN) caller and at least one TP caller. The scheduling software 
receives scheduling input from the IP user for the requested conference, according to the 
scheduling input fields, for communication to a server complex associated with the 
conference bridge. The control software is used for controlling selected aspects of a 

25 conference in progress that involves at least one public switched telephone network 

(PSTN) caller and at least one IP caller. The control software, in response to the IP user 
being provided with current state information for the conference, receives control input 
from the IP user for communication to a conference bridge in which the conference is 
implemented. 

30 In yet another embodiment, a system for conferencing callers includes a database 

that stores current state information for one or more conferences, at least one of the 
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conferences involving at least one PSTN caller and at least one IP caller. A conference 
bridge node coupled to the database generates conference traffic for communication to 
the callers, generates current state information for each conference for communication 
to IP users associated with the conferences and, in addition, periodically communicates 
5 current state information for each conference to the database for storage. The system also 

includes a server complex, coupled to the database and to the conference bridge node, 
that periodically accesses the stored current state information for at least one conference 
associated with an IP user and communicates at least some of that stored current state 
information to the IP user. 

1 0 The present invention provides a number of important technical advantages over 

previous conferencing systems. Unlike those systems, the present invention provides 
simultaneous conferencing of both PSTN and IP callers without requiring a separate IP 
gateway device to convert IP signals received from the IP callers into a format suitable 
for the conference bridge. The present invention allows IP callers to terminate directly 

1 5 to the conferencing system, without converting associated IP packets to PSTN signals 

prior to conferencing. The present invention also provides computing resources that are 
dedicated to conferencing, reducing or eliminating the conferee limitations associated 
with previous conferencing systems. The present invention incorporates a physically 
segmented backplane bus, one segment within each node and separated from all other 

20 segments, such that the nodes may be housed in a single chassis while communicating 

incoming user signals and outgoing conference traffic with one another using the TDM 
bus. The system typically has a lower initial cost relative to previous large-scale digital 
conferencing systems, and is readily scalable as conferencing needs grow. 

A server complex, an associated database, and software associated with one or 

25 more IP users may cooperate to allow the IP users to schedule conferences, change 

scheduled conferences, monitor conferences already in progress, exercise substantially 
real-time control over conferences they are moderating, monitoring, or participating in, 
and perform other appropriate activities. In response to a conference being scheduled, 
PSTN and IP callers are provided with confirmations containing information needed to 

30 join the conference, including a telephone number (PSTN caller) or an IP address (IP 

caller). As a result of these and other important technical advantages over previous 
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techniques, the present invention is well suited for modern distributed conferencing 
environments involving PSTN and IP traffic. Other technical advantages are readily 
apparent to those skilled in the art. 
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BRIEF DESCRIPTION OF THE DRAWINGS 

To provide a more complete understanding of the present invention and further 
features and advantages thereof, reference is now made to the following description taken 
in conjunction with the accompanying drawings, in which: 
5 FIGURE 1 illustrates an exemplary Internet-enabled conferencing system that 

accommodates PSTN and IP calls; 

FIGURE 2 illustrates an exemplary IP user; 

FIGURE 3 illustrates an exemplary chassis; 

FIGURE 4 illustrates an exemplary method of scheduling a conference; 
1 0 FIGURE 5 illustrates an exemplary web page for scheduling a conference; 

FIGURE 6 illustrates an exemplary conference confirmation; 
FIGURE 7 illustrates an exemplary method of joining a caller to a conference; 

and 

FIGURE 8 illustrates an exemplary method of participating in a conference as a 
1 5 moderator, monitor, or other IP user. 
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DETAILED DESCRIPTION OF THE INVENTION 

FIGURE 1 illustrates an exemplary Internet- enabled system 10 that provides 
audio, video, data or other conferencing for traffic originating within the public switched 
telephone network (PSTN) 12, within one or more Internet Protocol (IP) networks 14, or 
5 within both types of networks. Although PSTN 12 is discussed, PSTN 12 is meant to 

include any suitable telephone network or networks, public or private. One or more 
PSTN callers 16a are coupled to PSTN 12 and communicate audio, video, data, or other 
suitable PSTN traffic using PSTN 12. Similarly, one or more IP callers 16b are coupled 
to IP network 14 and communicate audio, video, data, or other suitable IP traffic using 

10 IP network 14, which may include one or more suitable local area networks (LANs), 
metropolitan area networks (MANs), wide area networks (WANs), a global computer 
network such as the Internet, or any other suitable network or networks that support IP 
communications. Callers 1 6a and 1 6b may be referred to in the singular as caller 16 and 
in the plural as callers 16, as appropriate. As indicated by dashed box 18, PSTN caller 

15 16a may also be an IP caller 16b, depending on the associated device and the type of 

traffic that caller 16 is communicating. Typically, dual callers 16 may use PSTN 12 in 
communicating voice and other "narrowband" audio information, while using the higher 
bandwidth of IP network 14 to communicate video, multi-media, data, and other 
"broadband" information. The present invention contemplates caller 16 using PSTN 12 

20 and IP network 14 in any suitable manner to communicate traffic. 

System 10 includes file server 20 and associated database 22, web server 24, IP 
traffic manager 26, and one or more network interface chassis 28 coupled using a LAN 
or other suitable network 30 supporting IP communications. In one embodiment, each 
chassis 28 is coupled to PSTN 12 using a corresponding communications link 32. As 

25 described more fully below with reference to FIGURE 3, each link 32 may include a 

separate trunk group dedicated to the corresponding chassis 28. LAN 30 is coupled to 
IP network 14 using link 34, which may be any communications link appropriate to 
communicate IP traffic between LAN 30 and IP callers 16b. Although a single complex 
of file server 20, associated database 22, web server 24, IP traffic manager 26, and 

30 multiple chassis 28 is shown, the present invention contemplates one or more such 
complexes (or components thereof) cooperating in any appropriate manner to provide 
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Internet-enabled conferencing functionality for PSTN and IP callers 16 in a distributed 
conferencing environment. 

File server 20 accesses and manipulates information contained in database 22 
according to the operation of system 10. For each caller 16, database 22 may contain, in 
5 any suitable combination and without limitation: (1) one or more names or other caller 

identifiers; (2) one or more user passwords; (3) one or more customer identifiers with 
which user 16 is associated, identifying entities that may be billed for conferences that 
are set up by or otherwise involve caller 16; (4) one or more billing or other physical 
addresses; (5) one or more e-mail, IP, medium access control (MAC), or other electronic 

10 addresses; (6) one or more telephone numbers; (7) one or more images of caller 16, for 

display to one or more other callers 16 joined in conferences with caller 16; and (8) any 
other appropriate personal information. In one embodiment, such information may be 
maintained in the form of an address book for caller 16, some or all of which may be 
displayed or otherwise conveyed during a conference to caller 16, other joined caller 16, 

15 a conference moderator, a conference monitor, or other suitable person, automatically or 

on request. Such an address book may be integrated or otherwise compatible with one 
or more suitable software application providing e-mail, organizer, and any other 
functions, for example, MICROSOFT OUTLOOK. 

File server 20 cooperates with components of chassis 28 during conferences, as 

20 appropriate. For example, and not by way of limitation, file server 20 may help provide 

interactive voice response (IVR) capabilities to interact with callers 16 wishing to join 
conferences. File server 20 may also facilitate the populating and periodic updating of 
database 22 with state information for conferences. For. each scheduled conference, 
database 22 may maintain the following state information, in any suitable combination 

25 and without limitation: (1) a conference identifier; (2) a customer identifier associated 

with the entity that is to be billed for the conference; (3) a scheduled start date and time; 
(4) a scheduled stop date and time; (5) a scheduled duration; (6) the number of callers 16 
anticipated or that have actually joined the conference; (7) the name or other identifier 
of each anticipated or joined caller 16; (8) the telephone number of each anticipated or 

30 joined caller 1 6; (9) the e-mail, IP, MAC, or other electronic address of each anticipated 

or joined caller 16; (10) an indicator of whether each anticipated or joined caller 16 is a 
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PSTN caller 1 6a or an IP caller 1 6b; (1 1) a timeslot assigned to each joined caller 1 6, in 
which incoming traffic from that caller 16 is carried; (12) a conference timeslot assigned 
to each joined caller 16, in which outgoing conference traffic to the caller 16 is carried; 
(13) a conference password; and (14) any other appropriate state information associated 
5 with the setting up, progress, or tearing down of the conference. 

In addition to being able to participate in conferences, one or more IP callers 16b 
may have access to conference control, web setup, and web monitoring software through 
an associated web browser or otherwise. Such IP callers 16b may be referred to as IP 
users 16b in connection with the use of such software. Although IP users 16b may 

10 participate in conferences as IP callers 16b, as described below IP user 16b need not 

participate in a conference as IP caller 16b to use such software. Web server 24 stores 
and pushes web pages, forms, e-mail notifications, and other suitable information to IP 
users 16b in connection with the setting up, progress, or tearing down of conferences. 
Web server 24 cooperates with conference control, web setup, and web monitoring 

15 software associated with IP user 16b to provide IP user 16b with an Internet-enabled 

interface to the conferencing resources associated with chassis 28. Web server 24 also 
supports resource allocation software used during operation of system 10 to determine, 
before allowing a requested conference to be set up, whether system 10 can support the 
conference and its various parameters. Resource allocation in system 10 is described 

20 more fully below with reference to FIGURE 3. Where appropriate, file server 20 

individually, web server 24 individually, or the combination of file server 20 and web 
server 24 may be referred to as a server complex. 

FIGURE 2 illustrates an exemplary IP user 16b that supports a voice over IP 
(VoIP) "screen phone" 30 or another ITU-T H.323 compatible end station suitable to 

25 communicate IP traffic using IP network 14. An example of such a screen phone is 

MICROSOFT NETMEETING. IP user 16b also supports conference control software 
32 suitable for use in connection with the setting up, progress, and tearing down of 
conferences according to the operation of system 10. IP user 16b may further support 
web setup software 44 and web monitoring software 46, which may be integral to or 

30 separate from one another and conference control software 42. Web setup software 44 

allows IP user 16b to set up conferences, using an associated web browser or otherwise, 
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in the manner described in FIGURE 4. If appropriate according to the authorization of 
user 1 6b as administrator, moderator, or otherwise, web monitoring software 44 allows 
user 16b to monitor some or all ongoing conferences, using an associated web browser 
or otherwise, in the manner described in FIGURE 8. In one embodiment, a system 
5 administrator might be entitled to monitor and receive information concerning some or 

all conferences and sub-conferences, while a moderator or monitor might be entitled to 
monitor and receive information concerning only a particular conference and any of its 
associated sub-conferences. 

IP user 16b is associated with at least one computer 48 that includes an input 

10 device 50 such as a keypad, touch screen, microphone, or any other device to accept 

information. An output device 52 of computer 48 may convey information to user 16b 
associated with the setting up, progress, and tearing down of conferences. Input device 
50 and output device 52 may support computer diskettes, CD-ROMs, or other fixed or 
removable storage media suitable to receive output from and provide input to user 16b 

15 and to components of system 10 through IP network 14. A processor 54 and associated 

volatile or non-volatile memory may execute instructions and manipulate information 
according to the operation of system 10. Where appropriate, reference to IP user 16b is 
meant to include computer 48, whether alone or in combination with a human user, 
unless otherwise indicated. Screen phone 40 operates on computer 48 and allows IP 

20 caller 16b to communicate IP traffic for conferences. Conference control software 42, 

web setup software 44, and web monitoring software 46 operate on computer 48 and 
collectively provide IP user 16b with an Internet-enabled interface to the resources and 
functionality of system 10, through an associated web browser or otherwise. 

FIGURE 3 illustrates an exemplary chassis 28 that includes voice nodes 60, a 

25 VoIP node 42, and a conference bridge node 44. Each node 40, 42, and 44 includes a 

dedicated central processing unit (CPU) card 66, which may incorporate a single board 
computer or any other suitable processing entity. In addition, voice nodes 60 and VoIP 
node 42 each include one or more voice traffic cards 48 or VoIP traffic cards 70, as the 
case may be. Although four voice nodes 60 and a single VoIP node 42 are shown, the 

30 present invention contemplates chassis 28 including more or fewer voice nodes 60 and 

VoIP nodes 62 according to the traffic chassis 28 is intended to support and the relative 
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capacities of nodes 50 and 42. Similarly, although voice nodes 60 are each shown as 
including a single voice traffic card 48, and VoIP node 42 is shown as including two 
VoIP traffic cards 70, the present invention contemplates more or fewer traffic cards 48 
and 50 according to particular needs. In addition to its CPU card 66, conference bridge 
5 node 44 includes a conference card 72 within which one or more conferences between 

callers 16 are implemented. 

The voice cards 68, VoIP card 70, and conference card 72 are coupled to and 
communicate user traffic with each other using a time division multiplexed (TDM) bus 
74. TDM bus 74 may be an ITU-T H.100 Peripheral Component Interconnect (PCI) or 

10 ITU-T H.l 10 compact PCI (cPCI) bus, a Signaling Computing bus (SCbus), a Multi- 
Vendor Integration Protocol (M VIP) bus, or any other TDM bus suitable to communicate 
user traffic between nodes 40, 42, and 44 during operation of system 10. As discussed 
above, link 32 for each chassis 28 may include a separate trunk group. Each such trunk 
group may be associated with one or more particular 800 or other telephone numbers, 

15 such that all calls from callers 16a to that telephone number are routed to a particular 

chassis 28. As shown in FIGURE 3, link 32 may include at least one Tl, El, or other 
appropriate digital telephone line 76 for each voice node 60. As further illustrated using 
the dashed oval 78, each voice node 60 may have multiple such lines 54, depending on 
the traffic voice node 60 is intended to support and the bandwidth associated with each 

20 line 76. In a particular embodiment, each of the voice cards 48 supports 48 ports and 

communicates with PSTN 12 using two Tl lines 76, each of the VoIP cards 70 supports 
30 ports, and chassis 28 is able to support conferences involving 252 total callers 16, 
although as discussed above chassis 28 may be configured to support any appropriate 
number of callers 16. 

25 The conferee limitations associated with previous conferencing systems are due, 

at least in part, to their use of software that depends on the primary CPU resources of the 
computer system on which it runs to manipulate the conference traffic. Even a relatively 
fast INTEL PENTIUM processor, for example, typically only supports seven or eight 
conferees in such an environment. In contrast to previous systems, system 10 provides 

30 conferencing functionality using a dedicated conference card 72 in conference node 44, 

having dedicated computer resources, with the desirable result that system 10 does not 
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suffer from the same capacity limitations plaguing such previous systems. As a result, 
system 10 provides an important technical advantage over such systems. 

In general, CPU card 66 within each voice node 60 and VoIP node 62 provides 
appropriate logic used in connection with the setting up, progress, and tearing down of 
5 conferences that involve associated callers 16. This may include answering calls from 

callers 16, detecting the dual tone multi-frequency (DTMF) or other digits that callers 1 6 
enter, providing appropriate IVR capabilities for interaction with callers 1 6, determining 
whether callers 16 who call in have provided a valid password to access the conference, 
determining whether callers 1 6 who call in and provide a caller identifier were previously 

10 identified during "detailed" conference setup (such that the names, images, and other 
personal information associated with these callers 16 may be conveyed to joined users 
16), and any other suitable activities. CPU cards 66 within voice nodes 60, VoIP node 
62, and conference bridge node 64 may cooperate with file server 20 to access and 
manipulate information contained in database 22 in providing such functionality. 

15 Voice cards 48 in voice nodes 60 receive the digitized and coded voice signals 

of PSTN callers 16a from lines 76 and, according to instructions from CPU card 66 in 
conference bridge node 64, place these signals on TDM bus 74 for communication to 
conference card 72 in conference bridge node 64. In one embodiment, the signals for 
each PSTN caller 16a are placed in a corresponding pre-assigned incoming timeslot on 

20 TDM bus 74, this association between PSTN callers 16a and incoming timeslots being 

"nailed up" or otherwise specified upon scheduling of the conference. Similarly, VoIP 
cards 70 within VoIP node 62 receive IP packets for IP callers 16b from LAN 30 and, 
according to instructions from CPU card 66, convert the packetized voice signals of IP 
callers 16b as appropriate and place them in pre-assigned incoming timeslots on TDM 

25 bus 74 for communication to conference card 72. 

In one embodiment, CPU cards 66 within chassis 28 are configured in a client- 
server architecture, with voice nodes 60 and VoIP node 62 operating as "clients" subject 
to the control of "server" CPU card 66 within conference bridge node 64. In response to 
a caller 16 calling in and connecting to a voice node 60 or VoIP node 62, CPU card 66 

30 of conference bridge node 64 receives signaling information from CPU cards 66 of that 

voice node 60 or VoIP node 62 using LAN 30. In one embodiment, the signaling 
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information received from CPU card 66 of voice node 60 or VoIP node 42 includes, for 
each user 16 that calls in, at least the conference identifier such that CPU card 66 of 
conference bridge node 64 can then determine the appropriate conference for caller 16. 
Conference card 72 receives all incoming timeslots carried on TDM bus 74 from voice 
5 cards 68 and VoIP card 70. 

For outgoing conference traffic, the CPU card 66 of conference bridge node 64 
instructs voice nodes 60 and VoIP node 62 which timeslot on TDM bus 74 to read for 
each caller 16. In one embodiment, each joined caller 16 will receive conference traffic 
corresponding to all the other joined caller 16, but will not receive the caller's own voice 

10 or other signals. Thus, for example and not by way of limitation, if three callers 1 6 have 

been joined in a conference, the first caller 16 will receive the voice signals of only the 
second and third callers 1 6, the second caller 1 6 will receive the voice signals of only the 
first and third callers 16, and the third caller 16 will receive the voice signals of only the 
first and second callers 16. Where IP user 16b or other conference moderator has opted 

15 to mute a j oined caller 1 6 using conference control software 42, voice or other signals for 

the muted caller 16 will not be communicated to IP user 16b or, instead or in addition, 
to other joined callers 16. Conference traffic received at voice cards 68 and VoIP card 
70 from the conference card 72 is communicated to appropriate joined callers 16a and 
16b using lines 76 and LAN 30, respectively. 

20 The cards within a particular node 60, 62, or 64 communicate with one another 

using a signaling backplane bus 80, which is physically segmented from other buses 58 
in chassis 28 such that signaling information carried over bus 80 is not communicated 
from node 60, 62, or 64 to another node 60, 62, or 64 within chassis 28. Due to typical 
hardware limitations, each bus 80 can have at most one driver, in this case associated 

25 CPU card 66. Providing multiple segmented buses 80 ~ one for each node 60, 62, and 

64 — allows multiple nodes 60, 62, and 64 to communicate conference traffic using a 
single TDM bus 74 within a single chassis 28, providing another important technical 
advantage. For example, if buses 80 were not segmented, each of the nodes 60, 62, and 
64 would require a separate chassis and a specialized card to communicate its TDM 

30 conference traffic from its chassis to chassis of other nodes 60, 62, and 64. According 

to the present invention, however, any voice card 68, VoIP card 70, or conference card 
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72 within chassis 28 may communicate information onto and receive information from 
any timeslot on TDM bus 74. 

As described more fully below, this helps enable many more callers 1 6 to join a 
conference than would be possible with prior systems, which typically limit the total 
5 number of conferees to eight or fewer. As just an example, in the particular embodiment 

in which chassis 28 supports 252 total callers 16, three of the many possible allocations 
of conferencing resources might include one conference of up to 252 callers 16, two 
conferences of up to 126 callers 16 each, and three conferences of up to 84 callers 16 
each. However, the conferencing capacity of chassis 28 may be allocated to one or more 

1 0 conferences in any suitable manner, according to particular needs. The present invention 

contemplates any combination of conferences and conferees within the limitations of 
conference bridge node 64 and TDM bus 74. 

Furthermore, unlike prior conferencing systems supporting both PSTN and IP 
callers, system 1 0 does not require a separate TP gateway device to convert packetized IP 

15 traffic to PSTN traffic prior to conferencing. Instead, EP traffic may terminate directly 

at VoIP card 70 within chassis 28. According to the present invention, the TP traffic is 
received from IP caller 16b at VoIP card 70, formatted as appropriate, and placed onto 
the incoming timeslot corresponding to IP caller 16b on TDM bus 74 for conferencing. 
In a similar manner, VoIP card 70 reads the outgoing conference traffic for IP caller 16b 

20 from the conference timeslot corresponding to IP caller 1 6b on TDM bus 74, according 

to instructions from conference node 46, formats it as appropriate, and communicates IP 
traffic to IP caller 16b. For PSTN caller 16a, the incoming and outgoing operations are 
analogous, except that no packetizing or depacketizing is necessary. Accommodating 
both PSTN and IP traffic, seamlessly and simultaneously, while eliminating the cost, 

25 complexity, and reliability concerns associated with a separate IP gateway device is 

another important technical advantage of the present invention. 

FIGURE 4 illustrates a method of scheduling a conference. The method begins 
at step 100, where IP user 16b uses associated web setup software 44, through a web 
browser or otherwise, to access web server 24 and its resources. Web server 24 pushes 

30 suitable web pages to IP user 16b according to input from IP user 16b and the operation 

of system 10. At step 102, if TP user 16b is a new user to system 10, IP user 16b may 
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register with system 10 as a new account, providing requested contact, billing, and any 
other suitable information. IP user 16b logs on using the corresponding account number 
and password at step 104 and, at step 106, selects an option from among a number of 
possible options. Options may include but are not limited to: (1) schedule a conference, 
5 (2) change one or more parameters associated with a scheduled conference, and (3) edit 

an address book for IP user 16b. If IP user 16b opts to schedule a conference at step 108, 
the IP user 16b may select a "detailed" setup, in which case the IP user 16b selects from 
an address book or otherwise specifies all callers 1 6 anticipated to join the conference (in 
addition to other parameters for the conference), or an "express" setup, in which case IP 

10 user 16b specifies only minimal parameters for the conference. 

If IP user 16b selects "detailed" setup at step 110, IP user 16b provides suitable 
conference parameters at step 112. As illustrated in FIGURE 5, which represents an 
exemplary hyper-text markup language (HTML) or other page 200 pushed to IP user 1 6b 
from web server 24 during conference setup, parameters may include, in any suitable 

1 5 combination and without limitation: (1) the start date and time 202, (2) the duration 204 

(or the stop date and time), (3) the maximum number 206 of callers 1 6, (4) the names or 
other identifiers 208 for all anticipated callers 16, (5) the conference password 210, and 
(6) the selected confirmation method 212. Referring again to FIGURE 4, if at step 112 
IP user 16b instead selects the "express" setup, DP user 16b provides less comprehensive 

20 conference parameters at step 1 14, which in one embodiment may simply include: (1) 

start date and time 202, (2) duration 204, and (3) maximum number 206 of callers 16. 
The present invention contemplates IP user 16b providing any appropriate conference 
parameters, whether in "detailed," "express," or any othermode to schedule a conference 
using the Internet-enabled front end associated with system 10. 

25 At step 1 1 0, in response to receiving the conference parameters from IP user 1 6b 

at step 1 12 or 1 14, web server 24 queries file server 20 and its associated database 22 to 
determine whether sufficient resources are available to support the conference as it has 
been requested. For example, in a particular embodiment in which system 10 includes 
a single chassis 28 supporting 252 concurrent callers 16, assume two conferences each 

30 involving 100 callers 16 were previously scheduled to begin on March 1, the first from 

9:00-11:00 a.m. and the second from 10:00-11:00 a.m. If TP user 16b has requested a 
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conference for 50 callers 16 from 9:00-1 1 :00 a.m. on March 1, then sufficient resources 
are available (since there will be at most 250 simultaneous callers 16 during any portion 
of the requested conference) and file server 20 reports this to web server 24 at step 118. 
However, if IP user 16b requested a conference for 60 callers 16 from 9:00-11:00 on 
5 March 1, or requested a conference for 160 callers from 9:00-10:00 on March 1, then 

sufficient resources are not available (since there would be up to 260 concurrent callers 
1 6 for at least part of the requested conference) and file server 20 reports this information 
to web server 24 at step 118. 

At step 120, if there are sufficient resources for the conference as it has been 

1 0 requested, web server 24 may prompt IP user 1 6b for confirmation at step 1 22 before web 

server 24, file server 20, and database 22 cooperate to allocate suitable resources to that 
conference at step 124. In one embodiment, this involves populating database 22 with 
some or all of the parameters for the conference, including an identifier assigned to the 
conference. Web server 24 informs IP user 16b of successful conference setup at step 

15 1 26, sends e-mail, facsimile, page, telephone, or other suitable conference confirmations 

to all or selected anticipated callers 16 at step 128, and the method ends. 

An exemplary conference confirmation 220 is illustrated in FIGURE 6. In one 
embodiment, confirmation 220 provides to anticipated caller 16 the following, in any 
suitable combination and without limitation: (1) schedule or other general conference 

20 information 222; (2) the 800 or other telephone number 224 associated with the assigned 

chassis 28 for the conference (for PSTN callers 16a who will join using PSTN 12); (3) 
an IP address 226 associated with IP traffic manager 26 or with VoIP node 62 in assigned 
chassis 28 (for IP callers 16b who will join using IP network 14); (4) conference entry 
information 228 that caller 16 may provide before joining the conference, including the 

25 conference identifier, conference password, the caller identifier for the caller, or other 
suitable information; and (5) instructions 230 for joining the conference using either 
PSTN 12 or IP network 14, as appropriate. Confirmation 220 may provide any other 
suitable information to caller 16 according to particular needs. 

Although an exemplary confirmation 220 is illustrated, confirmation 220 may 

30 have any appropriate format and content. Callers 16 receiving confirmations 220 may 

have an opportunity to send an e-mail or other reply to accept, tentatively accept, or reject 
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participation in the conference. Confirmations 220 sent to anticipated PSTN callers 16a 
may be the same or different from confirmations 220 sent to anticipated IP callers 16b. 
For example, confirmations 220 sent to PSTN callers 16a may include only telephone 
number 224 and instructions 230 needed to join using PSTN 1 2, while confirmations 220 
5 sent to IP callers 16b might include only IP address 226 and instructions 230 needed to 

join using IP network 14. hi the alternative, for convenience or any other appropriate 
reason, confirmations 220 sent to all callers 16 may include the same information. For 
example, all confirmations 220 may include telephone number 224, IP address 226, and 
instructions 230 needed to join the conference using PSTN 12 and IP network 14, 

10 respectively. 

Referring again to FIGURE 4, if sufficient resources are not available for the 
conference as requested at step 120, then web server 24, file server 20, and database 22 
cooperate to identify one or more alternatives that might be suitable to IP user 1 6b at step 
130. For example, in the particular example discussed above, system 1 0 may determine 

15 that although the conference cannot be setup exactly as requested, sufficient resources 

exist on March 1 for a conference for 160 callers from 1 1:00 a.m to 1:00 p.m. (instead 
of from 9:00-1 1 :00 a.m. One or more of the alternatives identified, according to any 
appropriate algorithm, are presented to IP user 16b at step 132, IP user 16b selects an 
identified alternative at step 134, and the method returns to step 124 for allocation of 

20 suitable resources. In one embodiment, the requested conference may be treated as a 

"block" of time of the requested duration 204 having the requested maximum number 
206 of callers 16. To identify an alternative, web server 24, file server 20, and database 
22 may cooperate to "slide" this time block forward, backward, or both forward and 
backward in time until it is consistent with the available resources. 

25 Alternatively, the requested conference may be viewed as a "block" of callers 1 6 

for which the requested start date and time 202, duration 204, or other parameters may 
be modified in identifying alternatives. These and other suitable schemes may be used 
until a predetermined number of alternatives are identified, the number of alternatives 
within a specified range of the requested conference (in terms of start time, duration, 

30 number of callers 1 6, or any other suitable parameters) have been exhausted, or any other 

conditions are satisfied, according to particular needs. As discussed more fully above 
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with reference to FIGURE 3, system 10 allocates resources to conferences dynamically 
in an on-line transaction processing (OLTP) environment, in substantially real time, so 
that requesting IP user 1 6b may be informed substantially immediately that the requested 
conference can be scheduled as requested or, if not, of one or more alternatives from 
5 which to choose. This provides an important technical advantage over systems relying 

on batch processing to allocate resources to conferences. 

If IP user 1 6b does not wish to schedule a new conference at step 1 08 , but instead 
selects the option to change one or more parameters for a scheduled conference at step 
136, IP user 16b identifies the conference at step 138 and submits at least the parameters 

10 to be changed at step 140. The method then returns to step 1 1 6 for determination of the 
available resources. For example only, and not by way of limitation, IP user 16b may 
wish to add or delete one or more anticipated callers 16, scheduled start date and time 
202, or duration 204. At least any anticipated callers 16 who are added or deleted may 
receive confirmation 220 or other suitable confirmation of this occurrence. Other callers 

15 16 may also be notified of such changes. If start date and time 202 or duration 204 is 

changed, all anticipated callers 16 should preferably receive new confirmations 220 
indicating such changes at step 128. If no changes are to be made to the conference 
parameters at step 136, IP user 16b has selected another option and interacts with web 
server 24 and other components of system 10 accordingly at step 142, and the method 

20 ends. For example, IP user 16b may have selected an option enabling IP user 16b to 

change an associated address book, review account information, or perform any other 
suitable operation, according to particular needs. 

Once a conference has been scheduled and the conference start time has arrived, 
callers 16 may join or be joined to the conference. FIGURE 7 illustrates an exemplary 

2 5 method of j oining caller 1 6 to a scheduled conference, using either a "dial-in" procedure, 

a "dial-out" procedure, or a combination of these. The present invention contemplates 
using either or both of procedures to j oin callers 1 6 to a particular conference, according 
to particular needs. Although the joining of a typical caller 16 is discussed, the present 
invention contemplates a joining a conference moderator or monitor in an analogous 

30 manner. If caller 16 is calling in to join the conference at step 300 ("dial-in"), caller 16 

enters at step 302 the conference telephone number 224 (PSTN caller 16a) or IP address 
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226 (IP caller 1 6b) previously provided to the caller 1 6 in confirmation 220. At step 304, 
caller 16 connects to corresponding voice node 60 (PSTN caller 16a) or VoIP node 62 
(IP caller 16b) within assigned chassis 28. As described above, if IP address 226 within 
confirmation 220 is for IP traffic manager 26, rather than for one of the VoIP cards 70 
5 within chassis 28, IP caller 16b may first connect to IP traffic manager 26, which is 

responsible for routing IP user 16b to the destination VoIP card 70. 

Voice node 60 or VoIP node 62 may interact with caller 16 using associated IVR 
capabilities or otherwise, to request input from caller 16 at step 306. At step 308, caller 
16 enters conference entry information 228 previously provided in confirmation 220. At 

1 0 step 310, caller 1 6 may further provide an associated caller identifier to allow the name, 

stored image, and any other personal information for caller 16 to be conveyed to one or 
more other callers 16 that have already joined or will later join the conference. At step 
312, CPU card 66 of voice node 60 or VoIP node 62 communicates a request to CPU 
card 66 of conference bridge node 64 to connect caller 16 to conference card 72 to join 

1 5 the conference. CPU card 66 of conference bridge node 64 responds to the request at step 

314 and, at step 316, caller 16 is connected to conference card 72. Caller 16 may need 
to provide a personal entrance code used for auditing participation in the conference, roll 
call, or any other suitable purpose. 

At step 318, caller 16 is joined to the conference, such that: (1) voice signals or 

20 other information originating at caller 1 6 may be received at voice card 68 of VoIP card 

70, formatted if necessary, and placed onto TDM bus 74 in the corresponding timeslot 
for communication to conference card 72; and (2) conference traffic from all or selected 
other callers 16 maybe placed on TDM bus 74 in the assigned conference time slot for 
communication to voice card 68 or VoIP card 70, properly formatted if necessary, and 

25 communicated to caller 1 6 using PSTN 12 or IP network 14. Substantially simultaneous 

with caller 1 6 being joined, conference node 52, file server 20, and database 22 cooperate 
at step 320 to update database 22 with information indicating caller 16 (whether or not 
identified according to a caller identifier) is joined, and the method ends. 

If a moderator or another authorized IP user 16b is calling out to join caller 16 to 

30 the conference at step 300 ("dial-out"), rather than caller 1 6 calling in to join, IP user 1 6b 

uses conference control software 42 to enter suitable control information at step 322, 
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which may include at least conference entry information 228. At step 324, IP user 16b 
enters the telephone number 224 (PSTN caller 16a) or IP address 226 (IP caller 16b) for 
the caller 16 to be joined. At step 326, conference bridge node 64 instructs appropriate 
voice node 60 or VoIP node 62 to place an outgoing PSTN or IP call to caller 16. Caller 
5 16 answer the call at step 328, is connected to voice node 60 or VoIP node 62 within 

assigned chassis 28 at step 330, and the method proceeds to step 316, where caller 16 is 
connected to conference card 72 to be joined to the conference. It maybe desirable to 
require callers 16 to provide a caller identifier or other authentication information prior 
to receiving conference traffic, as a security precaution. 

10 Callers 16 joined in a dial-out conference may participate immediately on being 

joined or placed on hold until all anticipated callers 16 are joined. In response to caller 
16 joining, an entry tone or other indicator may be provided to other joined callers 16. 
The name, image, and other personal information for new caller 16 may be provided to 
other joined callers 16 who are also IP users 16b (and thus have access to conference 

1 5 control software 42 or web monitoring software 46, through an associated web browser 

or otherwise) to make the conference more effective and more similar to face-to-face 
personal interaction. The present invention contemplates joining any number of callers 
16 to the conference serially, substantially simultaneously, or in any other appropriate 
manner and at any time during the conference, subject to available resources. 

20 In one embodiment, caller 1 6 may be played one or more pre-recorded messages 

before caller 16 begins to receive conference traffic. For example, one or more pre- 
recorded message may prompt caller 16 to provide a password or other authentication 
information, the authenticity of caller 16 maybe verified, and then caller 16 may begin 
receiving conference traffic. A message may be informational, for example, informing 

25 caller 16 that caller 16 is about to join a specified conference relating to specified subject 

matter or involving specified individuals. A message may be intended only for one or 
more selected callers 16, the message being played to those callers 16 in response to the 
callers 16 joining the conference or in response to the callers 16 additionally providing 
their caller identifiers. The present invention contemplates any appropriate message 

30 played to caller 16 before, during, or after caller 16 is joined to the conference or a sub- 

conference. 
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FIGURE 8 illustrates and exemplary method of participating in a conference as 
a moderator, monitor, or other IP user 16b using conference control software 42 or web 
monitoring software 46, through an associated web browser or otherwise. One or more 
moderators, monitors, or other IP users 16b may be referred to collectively as IP users 
5 16b. Each IP user 16b may have a privilege level determining the operations available 

to that IP user 1 6b through conference control software 42 and web monitoring software 
46 as a moderator, monitor, or other IP user 1 6b. The method begins at step 400, where 
some or all anticipated callers 16 are joined and the conference is progressing. At step 
402, assuming these joined callers 16 provided a name or other caller identifier upon 

10 joining the conference, the name, stored image, or any other personal information for 
each joined caller 16 maybe conveyed to IP users 16b. This allows at least the IP users 
16b who are also IP callers 16b to participate in a more natural and more productive 
conference environment than would be possible using only audio information. It further 
allows IP users 16b to readily determine who is currently participating in the conference 

15 as callers 16. Although conveying names, images, and other information to callers 16 

who are not also IP users 16b maybe impractical or otherwise less desirable, the present 
invention contemplates providing suitable information, beyond conference traffic, to 
callers 16 who are not also IP users 16b. 

In one embodiment, during the time a joined caller 16 is speaking, a colored or 

20 other speaking indicator may appear for IP users 1 6b at step 404 in association with the 

name, image, and other information for the speaking caller 16. The speaking indicator 
maybe provided in response to detecting at conference card 72 that the signal energy for 
caller 1 6 exceeds a predetermined threshold or in any other appropriate manner. At step 
406, IP user 16b may mute or subsequently unmute one or more callers 16 individually 

25 or in mass using conference control software 42. In one embodiment, to mute caller 16, 

conference control software 42 informs CPU card 66 of conference bridge node 64 and 
the CPU card 66 instructs conference card 72 to remove the information for caller 16 
from appropriate conference timeslots on TDM bus 74. To unmute caller 1 6, conference 
card 72 is similarly instructed to insert the information for caller 16 into appropriate 

30 conference timeslots. 
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At step 408, a caller 16 may alert or otherwise signal the moderator or other IP 
user 16b using the associated telephone keypad, screen phone keyboard, or in another 
suitable manner. A tone may sound, which maybe the same for some or all callers 16 
or unique for each caller 16, or a colored or other indicator may appear in association 
5 with the name, image, or other information for the particular caller 16 who is signaling. 

For example, it may desirable to preclude callers 16 from speaking until recognized. In 
such situations, an alert or other signal from a joined caller 16 to the moderator is akin 
to caller 16 raising a hand in a face-to-face meeting. Such a signaling feature may be 
used in conjunction with the muting feature described above to ensure that only one caller 

10 16 may be heard at any time during the conference. Caller 16 may alert or otherwise 

signal the moderator to vote in response to a polling inquiry or in any other suitable 
manner, according to particular needs. 

At step 410, the moderator may use conference control software 42 to cause a 
recorded announcement or message to be played to one or more callers 1 6. As described 

15 above with reference to FIGURE 7, such a message may be played to a caller 16 at any 

time before, during, or after caller 16 is joined to the conference. For example only, and 
not by way of limitation, a message might be intended for one or more selected callers 
16, those callers being required to provide their caller identifiers before receiving the 
message. Before or during the conference, at step 412, the moderator may use conference 

20 control software 42 to cause the conference to be recorded in whole or in part. A colored 

or other indicator may be conveyed to IP users 16b to inform them that the conference 
is being recorded. At step 414, the moderator may select and move callers 16 into one 
or more new or already progressing sub-conferences. Such "break-out" conferences may 
be initiated in response to one or more IP users 16b alerting or otherwise signaling the 

25 moderator. One or more callers 16 being moved to a sub-conference may be played a 

pre-recorded message before receiving conference traffic in the sub-conference. As 
discussed above, where a message is intended for selected callers 1 6, it may be desirable 
to require the selected callers 16 to provide their caller identifiers before receiving the 
message. Sub-conferences may be for the primary purpose of playing a message to the 

30 callers 16 moved to the sub-conference, while preventing callers 16 remaining in the 

main conference from hearing the message. 

DAL01:509446.1 



Docket No. 067575.0103 



PATENT 



24 

A new caller 16 may join the conference at step 416, according to a dial- in, dial- 
out, or other suitable procedure, and an entry tone or other indicator provided to other 
joined callers 16 at step 418. In one embodiment, at anytime during the conference, the 
moderator may use conference control software 42 to "lock-out" or otherwise block the 
5 entry of new callers 16. The present invention contemplates joining new callers 16atany 

time during the conference, subject to the availability of resources. In one embodiment, 
if the name, stored image, or other personal information for the newly joined caller 16 
is not conveyed automatically to the moderator or other IP users 16b, the moderator or 
other IP users 16b may access an associated address book to select information to be 

10 conveyed at step 420. 

For example, the address book may include the stored images of a number of 
potential callers 1 6 with which an already IP user 1 6b has had or might in the future have 
a conference. According to particular needs, a company might choose to include stored 
images of all of its employees in the address books of all its employees. Upon learning 

15 that one of the potential callers 16 has joined the conference, IP user 16b may access an 

associated address book to select the image of the newlyjoined caller 16 at step 420 such 
that it may be conveyed visually to the selecting IP user 16b. Where the conference is 
a videoconference, providing a stored image of each joined caller 16 maybe redundant 
and thus less desirable, whereas providing the name of each joined caller 16 may still be 

20 a desirable feature even in that situation. IP users 16b may also label a newlyjoined 

caller 1 6 with suitable text to indicate a title, an employment position, a role with respect 
to the topic of the conference, or any other appropriate information. 

As the conference proceeds, at step 422, CPU card 66 of the conference bridge 
node 64 maintains substantially real time state information for the conference and may 

25 communicate it to some (multi-cast) or all (broadcast) IP users 16b, making possible 

features such as those described above. At step 424, CPU card 66 of conference bridge 
node 64 cooperates with file server 20 to dynamically populate database 22 with the 
current state information for the conference. This may occur periodically according to 
any appropriate schedule or in response to appropriate events. The state information 

30 maintained in database 22 may be provided, in whole or in part, to IP users 16b using 

web monitoring software 46, through an associated web browser or otherwise. Based on 
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the state information maintained at conference bridge node 64 and communicated to IP 
users 16b, the IP users 16b are able at step 424 to exercise substantially real time control 
over aspects of the conference, such as those described above, using conference control 
software 42 and possibly an associated web browser. 
5 A joined caller 16 may leave the conference at any time at step 428, willingly or 

in response to the moderator disconnecting caller 16, and an exit tone or other indicator 
provided to other joined callers 16 at step 430. In one embodiment, to disconnect caller 
16, CPU card 66 of conference bridge node 64 instructs CPU card 66 of voice node 60 
or VoIP node 62 associated with caller 16, which in turn disconnects caller 16 from the 

10 associated voice card 68 or VoIP card 70. If all joined callers 16 have left the conference 

at step 432, the method ends. Otherwise, the conference continues in progress and the 
method returns to step 402 as described above. The present invention contemplates at 
least steps 404 through 414 (exemplary features), 416 (add caller 16 to the conference), 
and 428 (caller 1 6 leaves the conference) occurring in any relative order according to the 

1 5 progress of the particular conference. 

Although the present invention has been described with several embodiments, a 
plethora of changes, substitutions, variations, alterations, and modifications may be 
suggested to one skilled in the art, and it is intended that the invention encompass all 
such changes, substitutions, variations, alterations, and modifications as fall within the 

20 spirit and scope of the appended claims. 
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WHAT IS CLAIMED IS: 

1 . A system for scheduling a conference between callers, comprising: 

a database operable to store scheduling information indicating at least a start time, 
a duration, and a maximum number of callers for one or more scheduled conferences, the 
5 scheduling information reflecting available conferencing resources; 

a server complex coupled to the database and operable to: 

communicate, to a requesting Internet Protocol (IP) user, at least one page 
comprising one or more scheduling input fields; 

receive scheduling input from the requesting IP user for a requested 
10 conference according to the scheduling input fields; 

access the database to determine, according to the scheduling input, 
whether sufficient conferencing resources are available for the requested conference; 

if sufficient conferencing resources are available, allocate at least some 
available conferencing resources to the requested conference; and 
15 in response to determining sufficient resources are available, generate 

confirmations of the requested conference for communication to the callers. 

2. The system of Claim 1, wherein the scheduling input indicates at least a 
start time, a duration, and a maximum number of callers for the requested conference. 

20 

3. The system of Claim 2, wherein the scheduling input further comprises 
a caller identifier for one or more callers. 

4. The system of Claim 1, wherein the scheduling information specifies a 
25 type of confirmation each caller is to receive. 

5. The system of Claim 1, wherein: 

the confirmation for a public switched telephone network (PSTN) caller provides 
a conference telephone number; and 
30 the confirmation for an Internet Protocol (IP) caller provides an IP address. 
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6. The system of Claim 1 , wherein the confirmation provides a conference 
telephone number and a conference Internet Protocol address. 

7. The system of Claim 1, wherein the confirmation provides conference 
5 entry information selected from the group consisting of: 

a conference identifier; and 
a conference password. 

8 . The system of Claim 7, wherein the confirmation further provides a caller 
10 identifier for the particular caller receiving the confirmation. 

9 . The system o f Claim 1 , wherein the confirmation provides instructions for 
joining the conference to each caller, each caller being selected from the group consisting 
of: 

15 a public switched telephone network (PSTN) caller; and 

an Internet Protocol (IP) caller. 

10. The system of Claim 1, wherein the server complex is further operable, 
if sufficient conferencing resources are not available, to: 

20 generate alternative scheduling information for the requested conference; and 

communicate the alternative scheduling information to the requesting IP user for 
acceptance. 

1 1 . The system of Claim 1 , wherein the server complex comprises at least a 
25 web server. 
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12. A method of scheduling a conference between callers, comprising: 
storing in a database scheduling information indicating at least a start time, a 

duration, and a maximum number of callers for one or more scheduled conferences, the 
scheduling information reflecting available conferencing resources; 
5 communicating at least one page from a server complex to a requesting Internet 

Protocol (IP) user, the page comprising one or more scheduling input fields; 

receiving scheduling input from the requesting IP user for a requested conference 
according to the scheduling input fields; 

accessing the database using the server complex to determine, according to the 
10 scheduling input, whether sufficient conferencing resources are available for the 
requested conference; 

if sufficient conferencing resources are available, using the server complex to 
allocate at least some available conferencing resources to the requested conference; and 
in response, generating a confirmation at the server complex for communication 
15 to the callers. 

13. The method of Claim 12, wherein the scheduling input indicates at least 
a start time, a duration, and a maximum number of callers for the requested conference. 

20 14. The method of Claim 1 3 , wherein the scheduling input further comprises 

a caller identifier for one or more callers. 

1 5 . The method of Claim 1 2, wherein the scheduling information specifies a 
type of confirmation each caller is to receive. 

25 

1 6. The method of Claim 1 2, wherein: 

the confirmation for a public switched telephone network (PSTN) caller provides 
a conference telephone number; and 

the confirmation for an Internet Protocol (IP) caller provides an IP address. 
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1 7. The method of Claim 12, wherein the confirmation provides a conference 
telephone number and a conference Internet Protocol address. 

18. The method of Claim 12, wherein the confirmation provides conference 
5 entry information selected from the group consisting of: 

a conference identifier; and 
a conference password. 

19. The method of Claim 18, wherein the confirmation further provides a 
10 caller identifier for the particular caller receiving the confirmation. 

20. The method of Claim 12, wherein the confirmation provides instructions 
for joining the conference to each caller, each caller selected from the group consisting 
of: 

15 a public switched telephone network (PSTN) caller; and 

an Internet Protocol (IP) caller. 

21. The method of Claim 12, further comprising, if sufficient conferencing 
resources are not available, using the server complex to: 

20 generate alternative scheduling information for the requested conference; and 

communicate the alternative scheduling information to the requesting IP user for 
acceptance. 



22. The method of Claim 12, wherein the server complex comprises at least 
25 a web server. 
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23. Software associated with an Internet Protocol (IP) user, comprising: 
conference scheduling software operable to: 

provide at least one page to the IP user comprising one or more scheduling 
input fields for a requested conference involving at least one public switched telephone 
5 network (PSTN) caller and at least one IP caller; 

receive scheduling input from the IP user for the requested conference, 
according to the scheduling input fields, for communication to a server complex 
associated with the conference bridge; and 

control software for controlling selected aspects of a conference in progress, the 
1 0 conference involving at least one public switched telephone network (PSTN) caller and 

at least one IP caller, the control software operable to: 

in response to the IP user being provided with current state information 
for the conference, receive control input from the IP user for communication to a 
conference bridge in which the conference is implemented. 

15 

24. The software of Claim 23, wherein the scheduling indicates at least a start 
time, duration, and maximum number of callers for the requested conference. 

25 . The software of Claim 24, wherein the scheduling input further comprises 
20 a caller identifier for one or more callers. 

26. The software of Claim 24, wherein the scheduling information specifies 
a type of confirmation each caller is to receive. 

25 27. The software of Claim 23, wherein the conference control input specifies 

an outcome selected from the group consisting of: 

muting of one or more callers; 

unmuting of one or more callers; 

signaling of one or more callers; 
30 communicating a recorded message to one or more callers; 

involving one or more callers in a sub-conference; 
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adding one or more new callers; and 
removing one or more callers. 



28. The software of Claim 27, wherein the outcomes available to the IP user 
5 are determined according to a privilege level associated with the IP user. 



29. The software of Claim 23, further comprising monitoring software 
operable to: 

provide at least one page to the IP user comprising one or more monitoring input 

10 fields; 

receive conference monitoring input from the IP user according to the monitoring 
input fields, the monitoring input comprising a conference identifier for a conference to 
be monitored; and 

communicate the conference monitoring input to the conference bridge. 

15 
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30. A method implemented in computer software associated with an Internet 
Protocol (IP) user, comprising: 

providing at least one page to the IP user using conference scheduling software, 
the page comprising scheduling one or more scheduling input fields for a requested 
5 conference involving at least one public switched telephone network (PSTN) caller and 

at least one IP caller; 

receiving scheduling input from the IP user for the requested conference, 
according to the scheduling input fields, for communication to a server complex 
associated with a conference bridge; and 
10 in response to the IP user being provided with current state information for a 

conference in progress involving at least one public switched telephone network (PSTN) 
caller and at least one IP caller, receiving conference control input from the IP user using 
control software for communication to the conference bridge, the conference control 
input for controlling selected aspects of the conference. 

15 

3 1 . The method of Claim 30, wherein the scheduling indicates at least a start 
time, duration, and maximum number of callers for the requested conference. 

32. The method of Claim 3 1 , wherein the scheduling input further comprises 
20 a caller identifier for one or more callers. 

3 3 . The method of Claim 3 1 , wherein the scheduling information specifies a 
type of confirmation each caller is to receive. 

25 34. The method of Claim 30, wherein the conference control input specifies 

an outcome selected from the group consisting of: 

muting of one or more callers; 

unmuting of one or more callers; 

signaling of one or more callers; 
30 communicating a recorded message to one or more callers; 

involving one or more callers in a sub-conference; 
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adding one or more new callers; and 
removing one or more callers. 

35. The method of Claim 34, wherein the outcomes available to the TP user 
5 are determined according to a privilege level associated with the IP user. 

36. The method of Claim 30, further comprising: 

providing at least one page to the IP user using monitoring software, the page 
comprising monitoring input fields; and 
1 0 receiving monitoring input from the IP user, using the monitoring software and 

according to the monitoring input fields, for communication to the conference bridge, the 
monitoring input comprising a conference identifier for a conference to be monitored. 
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37. A system for conferencing callers, comprising: 

a database operable to store current state information for one or more conferences, 
at least one of the conferences involving at least one public switched telephone network 
(PSTN) caller and at least one Internet Protocol (TP) caller; 
5 a conference bridge node coupled to the database and operable to: 

generate conference traffic for communication to the callers; 
generate current state information for each conference for communication 
to IP users associated with the conferences; and 

in addition, periodically communicate current state information for each 
10 conference to the database for storage; and 

a server complex coupled to the database and to the conference bridge node, the 
server complex operable to: 

periodically access the stored current state information for at least one 
conference associated with an TP user; and 
1 5 communicate at least some of that stored current state information to the 

IP user. 



3 8 . The system of Claim 3 7, wherein the current state information comprises 
a caller identifier for each caller currently involved in the conference. 

20 

39. The system of Claim 37, wherein the current state information comprises 
an indication of which one or more callers are currently speaking. 

40. The system of Claim 37, wherein the conference bridge node is operable 
25 to generate the current state information for communication to IP users in substantially 

real time. 

41 . The system of Claim 37, wherein the server complex is further operable 

to: 

30 receive conference control input from an IP user according to the current state 

information; and 
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communicate one or more instructions to the conference bridge node according 
to the conference control input. 

42. The system of Claim 41, wherein the conference control input specifies 
5 an outcome selected from the group consisting of: 

muting of one or more callers; 
unmuting of one or more callers; 
signaling of one or more callers; 

communicating a recorded message to one or more callers; 
10 involving one or more callers in a sub-conference; 

adding one or more new callers; and 
removing one or more callers. 

43. The method of Claim 42, wherein the outcomes available to the IP user 
15 are determined according to a privilege level associated with the IP user. 

44. The system of Claim 37, wherein the conference bridge node is further 
operable to add a new caller to the conference in response to the new caller either 
entering a conference telephone number or entering a conference IP address. 

20 

45. The system of Claim 44, wherein the conference bridge node is further 
operable to generate an entry tone for communication to the callers in response to adding 
the new caller to the conference. 

25 46. The system of Claim 37, wherein the server complex comprises at least 

a web server. 
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47. A method for conferencing callers, comprising: 

storing in a database current state information for one or more conferences, at 
least one of the conferences involving at least one public switched telephone network 
(PSTN) caller and at least one Internet Protocol (IP) caller; 
5 generating conference traffic using a conference bridge node for communication 

to the callers; 

generating current state information for each conference using the conference 
bridge node for communication to IP users associated with the conferences; 

periodically communicating current state information for the conferences from 
1 0 the conference bridge node to the database for storage; 

using a server complex, periodically accessing the stored current state information 
for at least one conference associated with an IP user; and 

communicating at least some of that stored current state information from the 
server complex to the IP user. 

15 

48. The method of Claim 47, wherein the current state information comprises 
a caller identifier for each caller currently involved in the conference. 



49. The method of Claim 47, wherein the current state information comprises 
20 an indication of which one or more callers are currently speaking. 



50. The method of Claim 47, wherein the conference bridge node generates 
the current state information for communication to IP users in substantially real time. 



25 51. The method of Claim 47, further comprising: 

receiving conference control input from at least one IP user at the server complex 
according to the current state information; and 

communicating one or more instructions to the conference bridge node from the 
server complex according to the conference control input. 

30 
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52. The method of Claim 5 1 , wherein the conference control input specifies 
an outcome selected from the group consisting of: 

muting of one or more callers; 
unmuting of one or more callers; 
5 signaling of one or more callers; 

communicating a recorded message to one or more callers; 
involving one or more callers in a sub-conference; 
adding one or more new callers; and 
removing one or more callers. 

10 

53. The method of Claim 52, wherein the outcomes available to the IP user 
are determined according to a privilege level associated with the IP user. 



54. The method of Claim 47, further comprising using the conference bridge 
15 node to add a new caller to the conference in response to the new caller either entering 

a conference telephone number or entering a conference IP address. 



55. The method of Claim 54, further comprising using the conference bridge 
node to generate an entry tone for communication to the callers in response to adding the 
20 new caller to the conference. 



56. The method of Claim 47, wherein the server complex comprises at least 
a web server. 
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INTERNET-ENABLED CONFERENCING SYSTEM AND METHOD 
ACCOMMODATING PSTN AND IP TRAFFIC 

ABSTRACT OF THE DISCLOSURE 

A system for scheduling a conference between callers includes a database that 
stores scheduling information indicating at least a start time, a duration, and a maximum 
number of callers for one or more scheduled conferences, the scheduling information 
5 reflecting available conferencing resources. A server complex coupled to the database 

communicates, to a requesting Internet Protocol (IP) user, at least one page including one 
or more scheduling input fields. The server complex receives scheduling input from the 
requesting IP user for a requested conference according to the scheduling input fields. 
The server complex accesses the database to determine, according to the scheduling 
10 input, whether sufficient resources are available for the requested conference. If so, the 

server complex allocates at least some available resources to the requested conference 
and generates confirmations of the requested conference for communication to the 
callers. 
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Conference Setup j ^ 



Account Number: 154 
Account Name: eMeeting.net 

Setup Type | Detailed [▼][ 
Start Date 1 03/01/2000 



1 03/01/2000 Bj | 

loTH = [ooT3| [amTBI CDT r 



= . _ . }202 

Start Time 1 09 I 



Duration 1 02 IPm] Hrs 1 00 \\J__\\ Mins -*^ ?r)4 

Maximum Users [ 50 |f^|[ ^_onp 



Userl 



User 2 [[ 



User 50 £ 



Confirmation 
Method 



| E-mail KK212 
I Schedule Conference 



>208 



Conference 1 11 
Password I -T ^ 2 
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j Conference Confirmation ^ 



220 



The following information has been emailed to greg@bigco.com. If you would like to 
E-Mail or Print this information, click here. 



Conference Information for 

Greg Jones 



Scheduled by Larry Smith 
Account number 154 



Scheduled 02-07-2000 01:09PM 



This is to notify you of a scheduled Meet Me conference from 
eMeeting.net 

222^ Schedule: 

V Your Meet Me conference is scheduled for 50 users on 03/01/2000 and 
will last from 09:00AM until 09:59AM for a duration of 60 minutes. 



224- 



226- 



Conference phone number: 
(800) 555-6789 



Conference IP address: 
209.144.22.74 



Your conference ID is: 710 
Your conference password is: 99 



228 



230 



Participating through your telephone: 

1. Dial (800)555-6789. 

2. When prompted for conference ID, enter 71 0#. 

3. When prompted for Password, enter 9999#. 

Participating through the Internet: 

1 . Run Microsoft NetMeeting. 

2. Go to the Tools menu, select Options. 

3. Select the My Information tab. 

4. In the First Name field, enter 710. 

5. In the Last Name field, enter 9999. 

6. Click OK. 

7. Click the large Call button. 

8. In the Address field, enter 209.144.22.74. 

9. Click Call. 



If you need any help, call (214) 555-5353. Thank you for using 
eMeeting.net Meet Me Conferencing. 

(g) Setup another conference 
(g) Return to main account screen 
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304- 
306- 
308- 
310- 

312- 

314- 

316- 
318- 
320- 



( START ) 




CALLER ENTERS 
CONFERENCE TELEPHONE 
NUMBER OR IP ADDRESS 



CALLER CONNECTS TO 
DESTINATION INTERFACE NODE 



INTERFACE NODE INTERACTS 
WITH CALLER TO REQUEST INPUT 



CALLER ENTERS CONFERENCE 
ENTRY INFORMATION 



CALLER ENTERS USER IDENTIFIER 



INTERFACE NODE REQUESTS 

CONNECTION TO 
CONFERENCE BRIDGE NODE 



CONFERENCE BRIDGE 
NODE RESPONDS 



CALLER CONNECTED TO 
CONFERENCE CARD 



CALLER JOINED TO CONFERENCE 

i ~ 



UPDATE DATABASE TO 
INDICATE CALLER JOINED 

C END ) 

FIG. 7 



IP USER ENTERS 
CONTROL INFORMATION 



IP USER ENTERS 
TELEPHONE NUMBER 
OR IP ADDRESS OF 
USER TO BE JOINED 



CONFERENCE BRIDGE NODE 
INSTRUCTS INTERFACE 
NODE TO CALL CALLER 



CALLER ANSWERS CALL 



CALLER CONNECTED 
TO INTERFACE NODE 



-322 
-324 

-326 

-328 
-330 
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400- 
402- 

404- 

406- 
408- 
410- 

412- 

414- 
416- 



( START ) 



CONFERENCE IN PROGRESS 



NAME AND IMAGE OF EACH 
JOINED USER CONVEYED TO AT 
LEAST OTHER JOINED IP USERS 



SPEAKING INDICATOR 
CONVEYED TO IP USERS 
WHEN A CALLER SPEAKS 



MODERATOR MAY MUTE 
OR UNMUTE A CALLER 



cal.u?r MAY SIGNAL MODERATOR 



MODERATOR MAY CAUSE 
MESSAGE TO BE PLAYED 



MODERATOR MAY CAUSE 
CONFERENCE TO BE RECORDED 



MODERATOR MAY MOVE CALLERS 
INTO SUB-CONFERENCE 



NEW USER JOINED 



FIG. 8 



ENTRY TONES PROVIDED TO 
OTHER JOINED CALLERS 



xp *seRs SELECT INFORMATION 
TO BE CONVEYED FOR 
NEW CALLER 



CONFERENCE BRIDGE 
MAINTAINS CONFERENCE 
STATE INFORMATION 



CONFERENCE BRIDGE 
POPULATES DATABASE WITH 
CURRENT STATE INFORMATION 



I 



MODERATOR AND IP USERS 
EXERCISE SUBSTANTIALLY 
REAL TIME CONTROL OVER 
CONFERENCE ASPECTS 



-418 



-420 
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-424 
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